

09-07-00

A

Express Mail Label No. EK830777869US

JC490 U.S. PRO  
09/656146  
09/06/00


**UTILITY PATENT APPLICATION TRANSMITTAL**

(Large Entity)

(Only for new nonprovisional applications under 37 C.F.R. 1.53(b))

Docket No.  
POU9-1999-0183-US1

00/90/60  
U.S. PTO  
C917  
U.S. PTO  
00/90/60

**TO THE ASSISTANT COMMISSIONER FOR PATENTS**Box Patent Application  
Washington, D.C. 20231

Transmitted herewith for filing under 35 U.S.C. 111(a) and 37 C.R.F. 1.53(b) is a new utility patent application for an invention entitled:

High Speed Software Driven Emulator Comprised of a Plurality of Emulation Processors With Improved Multiplexed Data Memory

and invented by:

William F. BEAUSOLEIL, R. Bryan COOK, Tak-kwong NG, Helmut ROTH,  
Peter TANNENBAUM, Lawrence A. THOMAS, and Norton J. TOMASSETTI

If a **CONTINUATION APPLICATION**, check appropriate box and supply the requisite information:

Continuation  Divisional  Continuation-in-part (CIP) of prior application No.: \_\_\_\_\_

Which is a:

Continuation  Divisional  Continuation-in-part (CIP) of prior application No.: \_\_\_\_\_

Which is a:

Continuation  Divisional  Continuation-in-part (CIP) of prior application No.: \_\_\_\_\_

Enclosed are:

**Application Elements**

1.  Filing fee as calculated and transmitted as described below
2.  Specification having 12 pages and including the following:
  - a.  Descriptive Title of the Invention
  - b.  Cross References to Related Applications (*if applicable*)
  - c.  Statement Regarding Federally-sponsored Research/Development (*if applicable*)
  - d.  Reference to Microfiche Appendix (*if applicable*)
  - e.  Background of the Invention
  - f.  Brief Summary of the Invention
  - g.  Brief Description of the Drawings (*if drawings filed*)
  - h.  Detailed Description
  - i.  Claim(s) as Classified Below
  - j.  Abstract of the Disclosure

**UTILITY PATENT APPLICATION TRANSMITTAL**  
(Large Entity)  
(Only for new nonprovisional applications under 37 C.F.R. 1.53(b))

Docket No.  
POU9-1999-0183-US1

**Application Elements (Continued)**

3.  Drawing(s) (*when necessary as prescribed by 35 USC 113*)

a.  Formal Number of Sheets \_\_\_\_\_

b.  Informal Number of Sheets 2

4.  Oath or Declaration

a.  Newly executed (*original or copy*)  Unexecuted

b.  Copy from a prior application (37 CFR 1.63(d)) (*for continuation/divisional application only*)

c.  With Power of Attorney  Without Power of Attorney

d.  **DELETION OF INVENTOR(S)**

Signed statement attached deleting inventor(s) named in the prior application, see 37 C.F.R. 1.63(d)(2) and 1.33(b).

5.  Incorporation By Reference (*usable if Box 4b is checked*)

The entire disclosure of the prior application, from which a copy of the oath or declaration is supplied under Box 4b, is considered as being part of the disclosure of the accompanying application and is hereby incorporated herein by reference therein.

6.  Computer Program in Microfiche (Appendix)

7.  Nucleotide and/or Amino Acid Sequence Submission (*if applicable, all must be included*)

a.  Paper Copy

b.  Computer Readable Copy (*identical to computer copy*)

c.  Statement Verifying Identical Paper and Computer Readable Copy

**Accompanying Application Parts**

8.  Assignment Papers (*cover sheet & document(s)*)

9.  37 CFR 3.73(B) Statement (*when there is an assignee*)

10.  English Translation Document (*if applicable*)

11.  Information Disclosure Statement/PTO-1449  Copies of IDS Citations

12.  Preliminary Amendment

13.  Acknowledgment Postcard

14.  Certificate of Mailing

First Class  Express Mail (*Specify Label No.*): EK830777869US

**UTILITY PATENT APPLICATION TRANSMITTAL**

(Large Entity)

(Only for new nonprovisional applications under 37 C.F.R. 1.53(b))

Docket No.  
POU9-1999-0183-US1**Accompanying Application Parts (Continued)**15.  Certified Copy of Priority Document(s) (*if foreign priority is claimed*)16.  Additional Enclosures (*please identify below*):  
  
**Fee Calculation and Transmittal**

| <b>CLAIMS AS FILED</b>                                                          |               |                 |               |             |                                  |
|---------------------------------------------------------------------------------|---------------|-----------------|---------------|-------------|----------------------------------|
| <b>FOR</b>                                                                      | <b>#FILED</b> | <b>#ALLOWED</b> | <b>#EXTRA</b> | <b>RATE</b> | <b>FEES</b>                      |
| <b>Total Claims</b>                                                             | 4             | - 20 =          | 0             | x \$18.00   | \$0.00                           |
| <b>Indep. Claims</b>                                                            | 2             | - 3 =           | 0             | x \$78.00   | \$0.00                           |
| <b>Multiple Dependent Claims (check if applicable)</b> <input type="checkbox"/> |               |                 |               |             | \$0.00                           |
|                                                                                 |               |                 |               |             | <b>BASIC FEE</b> \$690.00        |
| <b>OTHER FEE (specify purpose)</b> _____                                        |               |                 |               |             |                                  |
|                                                                                 |               |                 |               |             | <b>TOTAL FILING FEE</b> \$690.00 |

A check in the amount of \_\_\_\_\_ to cover the filing fee is enclosed.

The Commissioner is hereby authorized to charge and credit Deposit Account No. 09-0463 as described below. A duplicate copy of this sheet is enclosed.

- Charge the amount of \$690.00 as filing fee.
- Credit any overpayment.
- Charge any additional filing fees required under 37 C.F.R. 1.16 and 1.17.
- Charge the issue fee set in 37 C.F.R. 1.18 at the mailing of the Notice of Allowance pursuant to 37 C.F.R. 1.31(b).

Dated: September 6, 2000



Signature

Lynn L. Augspurger, Attorney  
Reg. No. 24,227  
IBM Corporation  
Intellectual Property Law  
2455 South Rd., M/S P386  
Poughkeepsie, NY 12601  
Phone: (845) 433-1174  
Fax: (845) 432-9786

Docket Number: POU9-1999-0183-US1

HIGH SPEED SOFTWARE DRIVEN EMULATOR  
COMPRISED OF A PLURALITY OF  
EMULATION PROCESSORS WITH IMPROVED  
MULTIPLEXED DATA MEMORY

APPLICATION FOR

UNITED STATES LETTERS PATENT

"Express Mail" Mailing Label No.: EK830777869US

Date of Deposit: September 6, 2000

I hereby certify that this paper is being deposited with the United States Postal Service as "Express Mail Post Office to Addressee" service under 37 CFR 1.10 on the date indicated above and is addressed to the Assistant Commissioner for Patents, Washington, D.C. 20231.

Name: Billy R. Stacy

Signature: Billy R. Stacy  
Billy R. Stacy

INTERNATIONAL BUSINESS MACHINES CORPORATION

Title: HIGH SPEED SOFTWARE DRIVEN EMULATOR COMPRISED OF A PLURALITY OF EMULATION PROCESSORS WITH IMPROVED MULTIPLEXED DATA MEMORY

Cross Reference to Related Applications:

5 The following copending applications, assigned to the assignee of the present invention, contain common disclosure and are incorporated herein by reference in their entireties:

"High Speed Software Driven Emulator Comprised of a Plurality of Emulation Processors with Improved Board-to-Board Interconnection

10 Cable Length Identification System," Serial No. \_\_\_\_\_, filed \_\_\_\_\_, (Attorney Docket No. POU9-2000-0045-US1).

"High Speed Software Driven Emulator Comprised of a Plurality of Emulation Processors with an Improved Maintenance Bus that Streams Data at High Speed," Serial No. \_\_\_\_\_, filed

15 \_\_\_\_\_, (Attorney Docket No. POU9-2000-0046-US1).

"High Speed Software Driven Emulator Comprised of a Plurality of Emulation Processors with a Method to Allow High Speed Bulk Read/Write Operation Synchronous DRAM While Refreshing the Memory," Serial No. \_\_\_\_\_, filed \_\_\_\_\_, (Attorney Docket

20 No. POU9-2000-0047-US1).

"High Speed Software Driven Emulator Comprised of a Plurality of Emulation Processors with a Method to Allow Memory Read/Writes Without Interrupting the Emulation," Serial No. \_\_\_\_\_, filed \_\_\_\_\_, (Attorney Docket No. POU9-2000-0048-US1).

## Field of the Invention:

This invention relates to a software driven emulator comprised of a large plurality of processors operating in parallel with each capable of performing a logic function under program control, and 5 more particularly to a space efficient data and input memory stack shared by a cluster of processor.

## Trademarks:

S/390 and IBM are registered trademarks of International Business Machines Corporation, Armonk, New York, U.S.A. and Lotus is a 10 registered trademark of its subsidiary Lotus Development Corporation, an independent subsidiary of International Business Machines Corporation, Armonk, NY. Other names may be registered trademarks or product names of International Business Machines Corporation or other companies.

## 15 Background:

The usefulness of software driven emulators has increased enormously with growth in the complexity of integrated circuits. Basically, an emulation engine operates to mimic the logical design of a set of one or more integrated circuit chips. The 20 emulation of these chips in terms of their logical design is highly desirable for several reasons. The utilization of emulation engines has also grown up with and around the corresponding utilization of design automation tools for the construction and design of integrated circuit chip devices. In 25 particular, as part of the input for the design automation process, logic descriptions of the desired circuit chip functions are provided. The existence of such software tools for processing these descriptions in the design process is well

suited to the utilization of emulation engines which are electrically configured to duplicate the same logic function that is provided by a design automation tool.

Utilization of emulation devices permits testing and verification 5 via electrical circuits of logic designs before these designs are committed to a so-called "silicon foundry" for manufacture. The input to such foundries is the functional logic description required for the chip and its output is initially a set of photolithographic masks which are then used in the manufacture of 10 the desired electrical circuit chip device. Verifying that logic designs are correct in the early stage of chip manufacturing eliminates the need for costly and time-consuming second passes through a silicon foundry.

Another advantage of emulation systems is that they provide a 15 device that makes possible the early validation of software meant to operate the emulated chips. Thus, software can be designed, evaluated and tested well before the time when actual circuit chips become available. Additionally, emulation systems can also operate as simulator-accelerator devices thus providing a 20 high-speed simulation platform.

Emulation engines of the type contemplated by this invention contain an interconnected array of emulation processors (EP). Each emulation processor (hereinafter, also sometimes simply referred to as "processor") can be programmed to evaluate logic 25 function (for example, AND, OR XOR, NOT, NOR, NAND, etc.). The program driven processors operate together as an interconnected unit, emulate the entire desired logic design. However, as integrated circuit designs grow in size, more emulation processors are required to accomplish the emulation task. An 30 aim, therefore, is to increase the capacity of emulation engines

in order to meet the increasingly difficult task of emulating more and more complex circuits and logic functions by increasing the number of emulation processors in each of its modules.

For purposes of better understanding the structure and operation 5 of emulation devices generally, and this invention particularly, United States Patent No. 5,551,013 and patent application Serial No. 09/373,125 filed August 12, 1999 and assigned to the assignee of this application are hereby incorporated herein by reference.

10 Patent No. 5,551,013 shows an emulation module having multiple (e.g. 64) processors. All processors within the module are identical. The sequencer and the interconnection network occur only once in a module. The control stores hold a program created by an emulation compiler for a specified processor. The stack 15 memory, which is the subject of this invention, holds data and inputs previously generated and is addressed by fields in a corresponding control word to locate the bits for input to the processor logic element. During each step of the sequencer an emulation processor emulates a logic function according to the 20 emulation program. The data flow control interprets the current control word to route and latch data within the processor. The node-bit-out signal from a specified processor is presented to the interconnection network where it is distributed to each of the multiplexors (one for each processor) of the module. The node 25 address field in the control word allows a specified processor to select for its node-bit-in signal the node-bit-out signal from any of the processors within its module. The node bit is stored in the input stack on every step. During any operation the node-bit-out signal of a specified processor may be accessed by 30 none, one, or all of the processors within the module.

Data routing within each processor's data flow and through the interconnection network occurs independently of and overlaps the execution of the logic emulation function in each processor. Each control store stores control words executed sequentially 5 under control of the sequencer and program steps in the associated module. Each revolution of the sequencer causes the step value to advance from zero to a predetermined maximum value and corresponds to one target clock cycle for the emulated design. A control word in the control store is simultaneously 10 selected during each step of the sequencer. A logic function operation is defined by each control word.

Each of these emulation processors has an execution unit for processing multiple types of logic gate functions. Each emulation processor switches from a specified one logic gate 15 function to a next logic gate function in a switched-emulation sequence of different gate functions. The switched-emulation sequence of each of the processors thus can emulate a subset of gates in a hardware arrangement in which gates are of any type that the emulation processors functionally represent for a 20 sequence of clock cycles. The processors are coupled by a like number of multiplexors having outputs respectively connected to the emulation processors of a module and having inputs respectively connected to each of the other emulation processors. The bus connected to the multiplexors enables an output from any 25 emulation processor to be transferred to an input of any other of the emulation processors. In accordance with the teachings of the pending application, the basic design of the 5,551,013 patent is improved by interconnecting processors into clusters. With the processors interconnected in clusters, the evaluation phases 30 can be cascaded, and all processors in a cluster perform the setup and storing of results in parallel. This setup includes routing of the data through multiple evaluation units for the

evaluation phase. For most efficient operation, the input stack and data stack of each processor must be stored in shared memory within each cluster. Then, all processors perform the storage phase, again in parallel. The net result is multiple cascaded 5 evaluations performed in a single emulation step. Every processor in a cluster can access the input and data stacks of every other processor in the cluster and the less space on each module chip for the functions that support the processor operation, particularly the memory functions. While the 10 emulation processor described in the co-pending application has obvious advantages, as more and more components are placed on a single ET 4 chip, the availability of real estate on the chip becomes more and more a factor in the successful realization of an advanced emulation processor design.

15 15 Summary of the Invention:

An object of this invention is the provision of an emulation processor cluster input and data stack memory that makes more efficient use of the silicon real estate as compared with prior art emulation processor cluster designs.

20 Briefly, this invention contemplates the provision of an emulator processor cluster in which the read ports of a shared input and data memory stack are time multiplexed to serve more than one processor. In an exemplary embodiment of the invention, a 256 x 8 memory array serves as the shared memory for four processors in 25 a cluster. Two read ports are time multiplexed among the four processors in the cluster. On one read cycle, data from the two read ports is coupled to two processors. The next read cycle reads data from the same two ports to the remaining two

processors. In the preferred embodiment, the memory operates at twice the system clock speed so that overall emulation process execution time is not effected.

Brief Description of the Drawings:

5 The foregoing and other features and advantages of the invention will be described with reference to the accompanying drawings. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. Also in the figures, the left most digit of each  
10 reference number corresponds to the figure in which the reference number is first used.

Figure 1 is a block diagram of a four processor cluster of the type more fully described in copending application serial no. 09/373,125, and included here to illustrate the technology state  
2015 from which this invention departs.

Figure 2 is a block diagram of the cluster of Figure 1 (shown in less detail than in Figure 1) with multiplexed read port input and data memory in accordance with the teachings of this invention.

20 Detailed Description of the Invention:

Referring now to Figure 1, as described more completely in application serial no. 09/373,125, each cluster of four processors (Processor0, Processor1, Processor2 and Processor3) has a shared data and input memory stack to which and from which  
25 each processor in the cluster can write and read. In this exemplary emulation processor, the memory stack has 256

addressable eight-bit words. Each processor has four read ports for reading an eight-bit word from the data memory comprised of address inputs RA0; RA1; RA2; and RA3 and corresponding inputs to the four eight-to-one multiplexers whose select inputs are TAC0; 5 TAC1; TAC2 and TAC3 respectively. On each clock cycle, the inputs of the eight-to-one multiplexer of each of the four processors receives an eight-bit word from the memory. While generally satisfactory, there are a large number of processors (e.g. 64) and a correspondingly large number of memory stacks on a single 10 ET 4 emulator chip. Silicon real estate is in short supply and the stack memory output ports take up a lot of area on the chip.

Referring now to Figure 2, in accordance the teachings of the invention, the read ports of the data and input memory stack are 15 time multiplexed and the memory has only sets of two read ports to serve four processors, in this specific embodiment. So that the overall emulation process is not slowed, a memory stack read is carried out at twice the system clock speed. On one memory cycle, multiplexer 10 connects set A read address ports RA0, RA1, 20 RA2 and RA3 to address inputs for processor P0 and the corresponding four outputs as inputs to the four eight-to-one multiplexers of processor P0. Similarly, on this same memory cycle, multiplexer 12 connects set B read address ports to address inputs for processor P1 and the corresponding four 25 outputs as inputs to the four eight-to-one multiplexers of processor P1. On the next clock cycle, multiplexer 10 connects the set A read ports to address inputs for processor P2 and the corresponding four outputs as inputs to the four eight-to-one multiplexers of processor P2. Also multiplexer 12 connects the 30 set B read ports to address inputs for processor P3 and the corresponding four outputs as inputs to the four eight-to-one multiplexers of processor P3.

It will be appreciated that the teachings of this invention can be readily applied where there are eight processors in the cluster. Eight processors in a cluster can be time multiplexed to share four read ports, while the read clock for the memory 5 operates at two times the system clock. If the memory clock is operated at four times the system clock, the memory can be multiplexed so that two ports can serve all eight processors without slowing the emulation process.

While the preferred embodiment to the invention has been described, it will be understood that those skilled in the art, both now and in the future, may make various improvements and enhancements which fall within the scope of the claims which follow. These claims should be construed to maintain the proper protection for the invention first described.

What is claimed is:

1     Claim 1.   A software driven emulation engine comprising, in  
2     combination:

3                 a plurality of modules, each of said modules  
4     including a plurality of processors organized in clusters,  
5     each cluster comprised of a plurality of processors that  
6     access a data memory;

7                 a time division multiplexer coupling a set of read  
8     ports of said data memory to a set of read addresses of one  
9     processor of said cluster during one read cycle of said data  
10    memory and coupling said set of read ports of said data  
11    memory to a set of read addresses of another processor of  
12    said cluster during the next read cycle of said memory.

1     Claim 2.   A software driven emulation engine as in claim 1  
2     wherein said data memory operating clock rate for read  
3     operations is twice the operating clock rate of said module.

1     Claim 3.   A software driven emulation engine comprising in  
2     combination:

3                 a plurality of modules, each of said modules  
4     including a plurality of processors organized in clusters,  
5     each cluster comprised of a plurality of processors that  
6     access a data memory;

7                 a first time division multiplexer coupling a first  
8     set of read ports of said data memory to a set of read  
9     addresses of a first processor of said cluster during one  
10    read cycle of said data memory and coupling said first set  
11    of read ports of said data memory to a set of read addresses  
12    of a second processor in said cluster during the next read  
13    cycle of said memory;

14                 a second time division multiplexer coupling a  
15    second set of read ports of said data memory to a set of

16 read addresses of a third processor of said cluster during  
17 said one read cycle of said data memory and coupling said  
18 second set of read ports of a set of read addresses of a  
19 fourth processor in said cluster during said next read cycle  
20 of said memory.

1 Claim 4. A software driven emulation engine as in claim 3  
2 wherein said data memory operating clock rate for read  
3 operations is twice the operating clock rate of said module.

TITLE: HIGH SPEED SOFTWARE DRIVEN EMULATOR COMPRISED OF A PLURALITY OF EMULATION PROCESSORS WITH IMPROVED MULTIPLEXED DATA MEMORY

Abstract of the Disclosure:

5        In an emulator processor cluster, the read ports of a shared input and data memory stack are time multiplexed to serve more than one processor. In an exemplary embodiment of the invention, a 256 x 8 memory array serves as the shared memory for four processors in a cluster. Two read ports are time multiplexed  
10 among the four processors in the cluster. On one read cycle, data from the two read ports is coupled to two processors. The next read cycle reads data from the same two ports to the remaining two processors. In the preferred embodiment, the memory operates at twice the system clock speed so that overall  
15 emulation process execution time is not effected.



IBM CONFIDENTIAL



## DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION

As a below named inventor, I hereby declare that:

My residence, post office address and citizenship are as stated below next to my name. I believe I am the original, first and sole inventor (if only one name is listed below) or an original, first and joint inventor (if plural names are listed below) of the subject matter which is claimed and for which a patent is sought on the invention entitled **HIGH SPEED SOFTWARE DRIVEN EMULATOR COMPRISING OF A PLURALITY OF EMULATION PROCESSORS WITH IMPROVED MULTIPLEXED DATA MEMORY**

the specification of which (check one)

is attached hereto  
 was filed on \_\_\_\_\_ as United States Application Number \_\_\_\_\_  
 or PCT International Application Number \_\_\_\_\_  
 and was amended on \_\_\_\_\_.

I hereby state that I have reviewed and understand the contents of the above identified specification, including claims, as amended by any amendment referred to above. I acknowledge the duty to disclose to the U.S. Patent and Trademark Office all information known to me to be material to patentability as defined in 37 CFR Section 1.56.

I hereby claim foreign priority benefits under 35 U.S.C. Section 119(a)-(d) or Section 365(b) of any foreign application(s) for patent or inventor's certificate, or Section 365(a) of any PCT International application which designated at least one country other than the United States, listed below and have also identified below any foreign application for patent or inventor's certificate, or PCT International application having a filing date before that of the application on which priority is claimed.

## Priority Claimed

Yes  No  
 (Number) (Country) (Day/Month/Year Filed)

Yes  No  
 (Number) (Country) (Day/Month/Year Filed)

I hereby claim the benefit under 35 U.S.C. Section 119(e) of any United States provisional application(s) listed below.

(Application Number)  (Filing Date)

(Application Number)  (Filing Date)

I hereby claim the benefit under 35 U.S.C Section 120 of any United States application(s), or Section 365(c) of any PCT International application designating the United States, listed below and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior United States or PCT International application in the manner provided by the first paragraph of 35 U.S.C. Section 112, I acknowledge the duty to disclose material information as defined in 37 CFR Section 1.56(a) which occurred between the filing date of the prior application and the national or PCT international filing date of this application:

(Appl. Serial No.)  (Filing Date)  (Status) (patented, pending, abandoned)

(Appl. Serial No.)  (Filing Date)  (Status) (patented, pending, abandoned)

POWER OF ATTORNEY: As a named inventor, I hereby appoint the following attorney(s) and/or agent(s) to prosecute this application and transact all business in the Patent and Trademark Office connected therewith:

ADDED PAGE TO COMBINED DECLARATION AND POWER OF ATTORNEY  
FOR SIGNATURE BY FIRST AND SUBSEQUENT INVENTORS

Lynn L. Augspurger, Reg. No. 24,227; Lawrence D. Cutter, Reg. No. 28,501; Marc A. Ehrlich, Reg. No. 39,966; Floyd A. Gonzalez, Reg. No. 26,732; William A. Kinnaman, Jr., Reg. No. 27,650; Lily Neff, Reg. No. 38,254; William B. Porter, Reg. No. 33,135; Christopher A. Hughes, Reg. No. 26,914; Edward A. Pennington, Reg. No. 32,588; John E. Hoel, Reg. No. 26,279; Joseph C. Redmond, Jr., Reg. No. 18,753; Andrew J. Wojnicki, Jr., Reg. No. 43,995; Richard L. Aitken, Reg. No. 18,791; Clifton E. McCann, Reg. No. 29,565; John P. Shannon, Reg. No. 29,276; Laurence J. Marhoefer, Reg. No. 21,091; Andrew C. Aitken, Reg. No. 36,729; and Ralph P. Albrecht, Reg. No. 43,466.

**Send Correspondence to:** Laurence J. Marhoefer  
VENABLE  
P. O. Box 34385  
Washington, D.C. 20045-9998

**Telephone:** (202) 962-4800

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

Full Name of sole or first inventor: William F. BEAUSOLEIL

Signature: William F. Beausoleil Date: 8/31/2000  
Residence: 21 Bykenhulle Road, Hopewell Junction, New York 12533  
Citizenship: United States  
Post Office Address: Same as above

Full Name of second joint inventor: Bryan R. COOK R. Bryan Cook RBC

Signature: R. Bryan Cook Date: 9/5/2000  
Residence: 29 Round Hill Road, Poughkeepsie, New York 12603  
Citizenship: United States  
Post Office Address: Same as above

Full Name of third joint inventor: Tak-kwong NG

Signature: Tak-kwong Ng Date: 8/31/2000  
Residence: 118 Roosevelt Road, Hyde Park, New York 12538  
Citizenship: United States  
Post Office Address: Same as above

Full Name of fourth joint inventor: Helmut ROTH

Signature: Helmut ROTH Date: 9/11/2000  
Residence: 69 Dakota Drive, Hopewell Junction, New York 12533  
Citizenship: German  
Post Office Address: Same as above

ADDED PAGE TO COMBINED DECLARATION AND POWER OF ATTORNEY  
FOR SIGNATURE BY FIFTH AND SUBSEQUENT INVENTORS

Full Name of fifth joint inventor: Peter TANNENBAUM

Signature: Peter Tannenbaum Date: 8/31/2000

Residence: Woodstock, New York

Citizenship: United States

Post Office Address: P. O. Box 172, Woodstock, New York 12498

Full Name of sixth joint inventor: Lawrence A. THOMAS

Signature: Lawrence A. Thomas Date: 9/1/2000

Residence: 100 Pleasant Ridge Drive, West Hurley, New York 12491

Citizenship: United States

Post Office Address: Same as above

Full Name of seventh joint inventor: Norton J. TOMASSETTI

Signature: Norton J. Tomasetti Date: 9/1/2000

Residence: 169 Parsell Street, Kingston, New York 12401

Citizenship: United States

Post Office Address: Same as above